sorting - SQLite 计数、分组和按计数排序
全部标签 输入字符串:1654AaBcDddeeFF输出字符串:1456acddeeABDFF我试过的代码:test_array=[]'1654AaBcDddeeFF'.each_bytedo|char|test_array1456ABDFFacddee但我希望最后看到大写字符。 最佳答案 这个呢?p'1654AaBcDddeeFF'.each_char.sort_by(&:swapcase).join#=>"1456acddeeABDFF"编辑:正如@CarySwoveland指出的那样,.chars只是.each_char.to_a的快捷
我有一个散列:sample={bar:200,foo:100,baz:100}如何使用sort_order中的键顺序对sample进行排序:sort_order=[:foo,:bar,:baz,:qux,:quux]预期结果:sample#=>{foo:100,bar:200,baz:100}我能想到的就是new_hash={}sort_order.each{|k|new_hash[k]=sample[k]unlesssample[k].nil?}sample=new_hash必须有更好的方法。提示?不应该出现没有值的键,即键的数量保持不变,SortHashKeysbasedonord
我有一个文件,每一行都有数字:010110101311010113114311010431420我想要一个包含每个数字出现次数的散列,在这种情况下:{0101=>2,1010=>2,1311=>2,431=>2,420=>1}我该怎么做? 最佳答案 简单的一行代码,给定一个数组items:items.inject(Hash.new(0)){|hash,item|hash[item]+=1;hash}工作原理:Hash.new(0)创建一个新的Hash,其中访问未定义的键返回0。inject(foo)使用给定的block遍历数组。对于
如何根据变量alpha的每个字母对重音单词数组进行排序。下面的代码只引用了第一个字母的alpha,所以我无法获得“ĝusti”、“ĝustivin”、“ĝuspa”到正确排序。我需要这样的代码来对单词进行排序:["bonanmatenon","ĉuviparolasesperanton","ĝuspa","ĝusti","ĝustivin","miamasvin","pacon"]defalphabetize(phrases)alpha="abcĉdefgĝhĥijĵklmnoprsŝtuŭvz".split(//)phrases.sort_by{|phrase|alpha.index
我认为这很容易,并且已经很努力地搜索过,但似乎无法让它工作。我有以下哈希:@friends=[{"name"=>"JohnSmith","id"=>"12345"},{"name"=>"JaneDoe","id"=>"23456"},{"name"=>"SamuelJackson","id"=>"34567"},{"name"=>"KateUpton","id"=>"45678"}]我正在尝试按名称的字母顺序对其进行排序。现在我正在这样做:@friends.sort{|a,b|a[0]b[0]}但是,它只是以非字母顺序输出完整结果。 最佳答案
这是我的文件内容。Receivables=PorcobrarPayables=CuentosporpagarytdPurchases.label=PurchasesYTDvalidationError.maxValue=Valueistoolarge,maximumvalueallowedis{0}我想按字母顺序对这些内容进行排序...我该怎么做??更新:此代码将对我的文件进行排序。new_array=File.readlines("#{$base_properties}").sortFile.open("#{$base_properties}","w")do|file|new_arr
由于符号不响应sort使用的方法,有没有人有对符号数组进行排序的技术?有兴趣看到一些其他的想法。 最佳答案 嗯,symbols.sort_by{|sym|sym.to_s}有效。也在1.9符号中做响应,所以你可以做symbols.sort. 关于ruby-on-rails-ruby:对符号数组进行排序,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4129887/
有没有一种有效的方法来做到这一点。我有一个数组a=[1,2,2,3,1,2]我想按升序输出出现的频率。示例[[3,1],[1,2],[2,3]]这是我的ruby代码。b=a.group_by{|x|x}out={}b.eachdo|k,v|out[k]=v.sizeendout.sort_by{|k,v|v} 最佳答案 a=[1,2,2,3,1,2]a.each_with_object(Hash.new(0)){|m,h|h[m]+=1}.sort_by{|k,v|v}#=>[[3,1],[1,2],[2,3]]
我想先按字符串对数组进行排序,然后再按数字对数组进行排序。我该怎么做? 最佳答案 解决棘手排序的一般技巧是使用#sort_by,该block返回具有主要和次要排序顺序的数组(如果需要,还可以返回第三等)a=['foo','bar','1','2','10']b=a.sort_bydo|s|ifs=~/^\d+$/[2,$&.to_i]else[1,s]endendpb#=>["bar","foo","1","2","10"]之所以可行,是因为Ruby定义了数组比较的方式。比较由Array#定义方法:Arraysarecompared
对于按日期分组,我使用了group_by方法。Example:Product.all.group_by{|d|d.created_at}#returnHash但是kaminari不支持Hash。我使用Mongoid,我需要通过页面导航(kaminari)按日期分组。怎么做到的? 最佳答案 Kaminari只支持数组分页例如Kaminari.paginate_array(an_array).page(1).per(10)group_by不是mongoid方法,它是Array的方法,它是对内存中的所有数据进行分组。为了使用mongoid